package com.xuwang.mapper;

import com.xuwang.pojo.CompanyInfo;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 企业档案信息(CompanyInfo)表数据库访问层
 *
 * @author yuepeng
 * @version 1.0
 * @since 2021-09-14 09:48:43
 */
public interface CompanyInfoMapper {

    /**
     * 查询所有数据
     *
     * @return 返回所有数据
     */
    List<CompanyInfo> selectAll();

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    CompanyInfo selectById(@Param("id") Integer id);

    /**
     * 根据模糊条件查询总个数
     *
     * @return 返回查询到的总个数
     */
    int selectForCount(@Param("companyName") String companyName,
                       @Param("address") String address,
                       @Param("licenseKey")String licenseKey,
                       @Param("type")String type);

    /**
     * 通过实体作为筛选条件查询
     *
     * @param limit       每页条数
     * @param companyName 模糊查询的企业名称
     * @param address 模糊查询的企业地址
     * @param licenseKey  模糊查询的许可证号
     * @param type        模糊查询的类型
     * @return 对象列表
     */
    List<CompanyInfo> selectForPage(@Param("companyName") String companyName,
                                    @Param("address") String address,
                                    @Param("licenseKey") String licenseKey,
                                    @Param("type") String type,
                                    @Param("index") int index,
                                    @Param("limit") int limit);

    /**
     * 新增数据
     *
     * @param companyInfo 实例对象
     */
    void insert(CompanyInfo companyInfo);

    /**
     * 修改数据
     *
     * @param companyInfo 实例对象
     * @return 影响行数
     */
    int updateById(CompanyInfo companyInfo);


    /**
     * 通过主键删除数据
     *
     * @param list 主键集合
     * @return 影响行数
     */
    int deleteById(List<String> list);

}